package org.dromara.commission.service;

import org.dromara.commission.domain.vo.LzshHandworkCommissionImportVo;
import org.dromara.commission.domain.vo.LzshHandworkCommissionVo;
import org.dromara.commission.domain.bo.LzshHandworkCommissionBo;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.mybatis.core.page.PageQuery;

import java.util.Collection;
import java.util.List;

/**
 * 手工佣金Service接口
 *
 * @author Lion Li
 * @date 2024-07-25
 */
public interface ILzshHandworkCommissionService {

    /**
     * 查询手工佣金
     *
     * @param id 主键
     * @return 手工佣金
     */
    LzshHandworkCommissionVo queryById(Long id);

    /**
     * 查询手工佣金
     *
     * @param businessCode   渠道视图_经营主体编码
     * @param agentName      代理商名称
     * @param accountPeriod  帐期
     * @return 手工佣金
     */
    LzshHandworkCommissionVo queryByBusinessCode(String businessCode, String agentName, String accountPeriod);

    /**
     * 分页查询手工佣金列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 手工佣金分页列表
     */
    TableDataInfo<LzshHandworkCommissionVo> queryPageList(LzshHandworkCommissionBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的手工佣金列表
     *
     * @param bo 查询条件
     * @return 手工佣金列表
     */
    List<LzshHandworkCommissionVo> queryList(LzshHandworkCommissionBo bo);

    /**
     * 新增手工佣金
     *
     * @param bo 手工佣金
     * @return 是否新增成功
     */
    Boolean insertByBo(LzshHandworkCommissionBo bo);

    /**
     * 修改手工佣金
     *
     * @param bo 手工佣金
     * @return 是否修改成功
     */
    Boolean updateByBo(LzshHandworkCommissionBo bo);

    /**
     * 校验并批量删除手工佣金信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);

    /**
     * 批量插入手工佣金
     *
     * @param list   手工佣金列表
     * @return 是否插入成功
     */
    boolean insertBatch(List<LzshHandworkCommissionImportVo> list, int num);

    /**
     * 批量删除手工佣金
     *
     * @param businessCode   渠道视图_经营主体编码
     * @param agentName      代理商名称
     * @return 是否删除成功
     */
    Boolean deleteByBcAndAn(String businessCode, String agentName);

    /**
     * 创建索引
     * @return 是否创建成功
     */
    public boolean creatIndex();
}
